草庐IT

Ruby if vs 行尾 if 行为不同?

全部标签

Ruby if .. elsIf .. else 在一行中?

使用ruby​​三元运算符,我们可以为简单的ifelse构造编写以下逻辑:a=true?'a':'b'#=>"a"但是如果我想把它写成iffoo'a'elsifbar'b'else'c'怎么办?我可以这样写,但是有点难理解:foo=truea=foo?'a':(bar?'b':'c')#=>"a"foo=falsebar=truea=foo?'a':(bar?'b':'c')#=>"b"是否有更好的选择来处理这种情况,或者如果我们希望将if..elsif..else逻辑压缩到一行中,这是我们最好的选择吗? 最佳答案 a=(foo&&

ruby - 为什么 array.slice 对 (length, n) 的行为不同

如果我有一个数组a:a[a.length]返回nil。好。a[a.length,x]返回[]。好。a[a.length+x,y]返回nil。与2不一致。虽然此行为是documented,看起来很奇怪。谁能解释一下这种设计背后的原因? 最佳答案 考虑一下a=[0,1,2,3]#=>[0,1,2,3]a[0,10]#=>[0,1,2,3]a[1,10]#=>[1,2,3]a[2,10]#=>[2,3]a[3,10]#=>[3]a[4,10]#=>[]a[5,10]#=>nil所以a[4,10]是3之间的切片和数组的末尾[]哪里a[4]和

ruby-on-rails - ruby /rails : How to determine if module is included?

在这里扩展我的问题(ruby/rails:extendingorincludingothermodules),使用我现有的解决方案,确定我的模块是否包含在内的最佳方法是什么?我现在所做的是在每个模块上定义实例方法,这样当它们被包含时,一个方法就可用,然后我只是向父模块添加一个捕获器(method_missing())所以如果它们不包括在内,我可以catch。我的解决方案代码如下:moduleFeaturesFEATURES=[Running,Walking]#includeFeatures::RunningFEATURES.eachdo|feature|includefeatureen

javascript - 在 respond_to 中呈现不同的 Javascript 文件

我陷入了一个(显然)简单的问题。在我的event_controller中,我有i_like_it操作:defi_like_it@event=Event.find(params[:id])...#logicrespond_todo|format|format.jsendend在我的例子中,“i_like_it”是用:method=>PUT调用的(它是一个Ajax调用,“i_like_it.js.erb”将作为脚本返回,它将是在浏览器上执行。)我想渲染一个具有不同名称的Javascript文件(不是i_like_it.js.erb),但我没有在RailsAPI中找到任何选项文档。respo

ruby - Ruby 中 '_'(下划线)的奇怪行为

只是好奇而已。如果您打开IRB并键入_,您将得到nil作为响应:irb(main):001:0>_=>nil你可以修改它的值:irb(main):002:0>_='somevalue'irb(main):003:0>_=>"somevalue"但是如果你用_创建一个新变量,它的值会被修改:irb(main):004:0>foo_bar='othervalue'irb(main):005:0>_=>"othervalue"为什么?这是设计决策吗? 最佳答案 irb使用_来引用最后计算的表达式的值。所以你会看到_改变了,即使你没有在前一

ruby - next 与 if 在 .each 循环中?

我正在用Ruby进行文本处理。基本上,我必须实现一个简单的状态机(带有一个字符后视)。我现在的代码是这样的:text.each{|c|............if@state!=:some_statenextend#processingstuffforifin:some_statemode...............}这样合适吗?或者它应该像这样实现:text.each{|c|............if@state==:some_state#processingstuffforifin:some_statemode...............end}有正确的方法还是只是偏好?哪个

ruby-on-rails - 在 Ruby on Rails 中, '#encoding: utf-8' 和 'config.encoding = "utf-8"' 是否不同?

我可以通过在其顶部添加注释行来指定任何ruby​​文件使用特定编码:#encoding:utf-8但是在Rails的config/application.rb中,我发现了这个:config.encoding="utf-8"它们有什么不同吗?如果我设置了config.encoding="utf-8",我还需要#encoding:utf-8吗? 最佳答案 config/application.rb中的config.encoding="utf-8"部分与Rails应如何解释内容有关。ruby文件中的#encoding:utf-8告诉rub

ruby - 使用不同的参数和默认值在 Ruby 中初始化类的最有效方法是什么?

我想要一个类和一些属性,您可以在初始化期间设置这些属性或使用其默认值。classFruitattr_accessor:color,:typedefinitialize(color,type)@color=color||='green'@type=type||='pear'endendapple=Fruit.new(red,apple) 最佳答案 解决此问题的典型方法是使用具有默认值的散列。如果散列值是方法的最后一个参数,Ruby有一个很好的传递散列值的语法。classFruitattr_accessor:color,:typedef

ruby - 类似 tap 的组合方法,但能够返回不同的值?

我正在经历一个尝试避免临时变量和过度使用条件的阶段,在这个阶段我可以使用更流畅的编码风格。我非常喜欢在想要获取需要返回的值的地方使用#tap,但在返回它之前对其进行一些处理。deffluid_methodsomething_complicated(a,b,c).tapdo|obj|obj.update(:x=>y)endendvs。程序:defnon_fluid_methodobj=something_complicated(a,b,c)obj.update(:x=>y)obj#显然上面的示例很简单,但这在ruby​​社区中仍然是一种非常常见的编码风格。有时我也会使用#inject通过

ruby - 在 Ruby 中,为什么 inspect() 会打印出某种与 object_id() 给出的不同的对象 ID?

p函数在打印出对象时,可能会给出一个ID,与object_id()给出的不同。不同数字的原因是什么?更新:0x4684abc不同于36971870,即0x234255E>>a=Point.new=>#>>a.object_id=>36971870>>a.__id__=>36971870>>"%X"%a.object_id=>"234255E" 最佳答案 inspect的默认实现调用了to_s的默认实现,它只是直接显示对象的十六进制值,如Object#to_s中所见docs(单击方法描述以显示来源)。同时,object_id实现的C源